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DIGITAL PROCESSING APPARATUS FOR FREQUENCY FILTERING 
WITH COMPUTATION OF REDUCED COMPLEXITY 

The invention relates to digital filters performing processing on a 
frequency domain function that corresponds to zeroing a portion of a time domain 
5 signal obtained by the inverse transform of such a frequency domain function. 

Such a frequency domain function can be frequency response, i.e. the 
transfer function of a filter, e.g. an adaptive filter, or it can be the Fourier transform of 
a time domain signal. 

In conventional manner, a digital filter performs operations on data that 
10 can either be data that is directly available at an input or an output of the filter, or else 
data that is obtained by applying a transform such as the Fourier transform, the 
Hartley transform, or some other transform. 

Use of such transforms, frequently implemented by means of fast 
algorithms, serves to reduce very considerably the number of arithmetical operations 
1 5 that need to be performed to process the data. 

Digital processing apparatus is often designed to perform convolution or 
correlation operations. Numerous applications based on adaptive processing of the 
signal thus require convolution (filtering) and correlation operations to be performed, 
which operations are performed on vectors having data or coefficients that are 
20 variable, said vectors often being large in size (several hundreds to several thousands 
of coefficients). 

In the field of telecommunications, acoustic and electrical echo cancelling, 
removing noise from speech, and transmission channel equalization, and in other 
fields, applications such as adaptive control, all make use of such techniques for 

25 adaptively processing a signal. 

Calculating a convolution or a correlation exactly often requires a 
constraint to be applied on the size of the time domain vector representing the filter or 
the data, i.e. a limit on the number of non-zero samples in the inverse transform of the 
frequency domain vector that is to be used, regardless of whether this frequency 

30 domain vector is the frequency response of a filter or the transform of a time domain 
signal that is to be processed. 

This constraint is conventionally implemented by applying an inverse 
transform on the data in the transform domain, i.e. the frequency domain, and then 
applying windowing that eliminates certain components of the time domain vector, 

35 and finally applying the forward transform so as to obtain the exact result in the 
transform domain. 
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When it is desired to make an optimum filter for application to a signal 
that is subject to disturbance, for example noise or echo, it is common practice to 
calculate the transfer function of the optimum filter from the affected signal, using 
some number of frequency domain points in the transform of the signal that is smaller 
5 than the total number of points of the signal 

In addition, since the frequency domain vector of the filter is short, exact 
computation of the output signal of the filter which needs to be performed by linear 
convolution often assumes that the impulse response of the optimum filter is extended 
by zeros. 

10 That operation of computing a long frequency response filter on the basis 

of a short frequency response filter by extending the impulse response of the filter 
with zeros is usually performed, yet again, by an intermediate passage through the 
time domain, extending the impulse response of the filter with zeros, and a forward 
transform so as to obtain the exact result in the transform domain. 

1 5 It will be understood that passing into the time domain in this way in order 

to apply constraint zeros, or indeed to extend the impulse response of an optimum 
filter by means of zeros, is expensive in terms of computation since it requires two 
transforms to be performed (a forward transform and an inverse transform). 

The theoretical bases showing the typical reasons why such constraints are 

20 often necessary are described below: 

The advantage of using a Fourier transform (FT) for filtering or for 
computing correlation stems from the fact that in the transform domain convolution 
and correlation operations are represented merely by multiplications. The description 
below relates solely to convolution, but correlation is entirely analogous thereto. 

25 Let h(n) be a filter of length L h , and x(n) an input signal to the filter. The 

output of the filter is then written: 

y{n) - x(n) *h(n) = £ A(i>(/i " ') = IFT [ FT N*)] ' FT [ h (n)]\ 

where FT[..] and IFT[..] designate the forward Fourier transform and the inverse 
Fourier transform, and where * designates the convolution operation. In practice, two 
30 difficulties prevent the above equation being used directly: 

- in order to calculate the Fourier transform of the signal, it is necessary to 
know the signal in full, i.e. all past and future samples, and that is not possible; and 

- in numerous applications such as echo cancelling or adaptive filtering, 
the filter h(n) varies in time. 

35 To resolve those problems, the person skilled in the art subdivides the 

signal into blocks of length N and associates each block b with a filter h b (n) of length 
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L h . In the general case, such blocks overlap. In order to simplify notation, it is 
assumed that the blocks are juxtaposed, but this condition is not necessary. 
Let: 

\x(n + bN)ifO<n<N-l 
x b (n) = < 

[0 elsewhere 

5 The output signal y(n) is given by: 

co 

y{n)=Y J y b (n-bN) with y b (n)=x b (n)*h b (n) 

In order to calculate the forward and inverse Fourier transforms, a fast 
method is used known as the "fast Fourier transform" (FFT X for a forward transform 
on T points, IFFT X for the inverse transform on T points). 
10 The signal y b (n) is zero for n<0 and n>T=N+L h -l, which means that the 

minimum number of points for calculating the transforms is equal to T. It can be 
proved that for 0<n<T-l, the following is obtained: 

y b (n) = IFFT r [FFT r [x,(n)]^FT r [^(^)]] = WVT T [X bJ (k)* H bJ (k)} 

In some cases, there is no need for all of the values of y b , but only for L y 
15 consecutive points. In which case, the size of the FFTs must satisfy: 
T^O^CN+Lh+Ly-l) 

This constraint is known as the linear convolution constraint. 

In practice, the following problem is often encountered: 

N (the size of a data block), T (the size of the FFT), and L y (the working 
20 length of the result) are set. X(k) is computed by the FFT and the filter H(k) by some 
arbitrary method directly in the transform domain on T points. The two factors for 
multiplication are thus available, but the condition that is necessary to ensure that 
filtering is correct: 

L h <2T-N-L y +l 

25 is not satisfied. The question is how to obtain a filter H(k) in the transform domain 
which is an approximation to H bjX (k), but which also satisfies the constraint. In the 
prior art, the inverse transform of H is computed, a portion of the signal is set to zero, 
and a forward transform of said extended function is recomputed in order to replace 
H. 

30 Another problem is also very frequently encountered. It is as follows: 

N (the size of a data block), T (the size of the FFT), and L y (the useful 
length of the result) are set. X(k) is calculated by the FFT and the filter H(k) by some 
arbitrary method directly in the transform domain on L^T/D<2T-N-L y +1 points. The 
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question is how to obtain a filter H(k) in the transform domain on T points instead of 
L which is an interpolation of H(k) and which satisfies the constraint L h <2T-N-L y +l. 

In the prior art, the inverse transform of H is computed, it is extended with 
zeros, a new function H is recomputed on the basis of the truncated inverse transform, 
5 and then by means of a forward transform. 

When there is a zero constraint, proposals have been made to avoid 
passing in this way via two successive transforms which are expensive in computation 
by means of processing (filtering) performed directly in the transform domain on the 
frequency domain data. 

10 When cancelling an acoustic echo, and more precisely in the field of block 

adaptive filters using the Fourier transform, frequently known as frequency domain 
adaptive filters (FDAF), Clark et al. [1] describe a general formalism from which it 
can be seen that it is necessary to apply a constraint on the length of the impulse 
response of the adaptive filter in order to obtain an exact algorithm, and they propose 

15 implementing convolution with the frequency response of the filter that is equivalent 
to multiplying by a window in the time domain. The number of coefficients in the 
proposed convolution is very high, thus maintaining very complex computation. 

Sommen et al. [5] describe another variant of FDAF in which the time 
constraint is implemented by convolution in the frequency domain: the authors 

20 propose applying smoothing to the frequency data representing the response of the 
filter, and in particular smoothing over three coefficients which is equivalent to 
weighting the time response by a cosine window. 

The maximum of the window is assumed to correspond to the dominant 
coefficients of the response, which assumption is highly restrictive. The justification 

25 given by those authors for their method lies in reducing adaptation noise associated 
with coefficient weighting, rather than seeking an approximation to the exact solution 
for applying a constraint. 

Other references are also mentioned, Mansour et al. [2] proposing a 
simplified FDAF without applying a constraint, giving rise to a considerable reduction 

30 in complexity but also to performance that is less good than that of algorithms having 
constraints. 

Prado et al. [3] also describe a generalized version of FDAF that they refer 
to generalized multi-delay filter with an oversampling factor of a (GMDFa), which 
makes it possible to process long impulse responses with shorter data blocks by 
35 segmenting the impulse response into short blocks, thereby reducing the processing 
delay in the algorithm. That algorithm uses the above-mentioned constraint. 



McLaughlin et al [4] describe a modified form of the FDAF algorithm 
that reproduces certain aspects of GMDF, in particular segmentation of the impulse 
response into short blocks, and they propose a technique of applying the constraint on 
the various blocks that varies over time in application of a well-defined scheme 

5 (implemented by a "scheduler"), which enables complexity to be limited while 
preserving the benefit of the constraint to some extent. 

The main object of the invention is to propose a digital filter acting on a 
frequency domain vector to perform convolution that is equivalent to windowing a 
time domain signal corresponding to said frequency domain vector, and that produces 

10 sufficient computation accuracy while requiring only a particularly small amount of 
computation. 

The invention achieves this object by digital data processing apparatus 
comprising a module implementing convolution with a function U on a frequency 
domain data vector Z(k) where k lies in the range 0 to N-l, which convolution 
15 corresponds to zeroing samples in the time domain of the inverse transform of Z(k), 
the apparatus being characterized in that the function U has the form: 



U(k) = sine 



e ^ 2 J .P{k) 



where ^ is a constant integer and P(k) is a weighting window that is symmetrical 
about k^. 

20 Such a filter has a number of coefficients that can be adjusted depending 

on the degree of approximation desired in the result, which number can be very small. 
In order to be implemented, such a filter requires a number of arithmetic operations 
that is considerably smaller than that required in conventional solutions. 

Other characteristics, objects, and advantages of the invention will appear 

25 on reading the following description made with reference to the accompanying 
figures, in which: 

- Figures 1 to 3 show respectively the modulus of the frequency response, 
the phase of the frequency response, and the impulse response of a filter; 

- Figures 4 to 6 shows respectively the modulus of the frequency response, 
30 the phase of the frequency response, and the impulse response of the filter of 

Figures 1 to 3 after the same zero constraint has been applied to them using a 
conventional two-transform apparatus; 

- Figures 7 to 9 show respectively the modulus of the frequency response, 
the phase of the frequency response, and the impulse response of the filter of 
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Figures 1 to 3 after a zero constraint has been applied to them using the apparatus of 
the invention; 

- Figures 10 to 12 show respectively the frequency modulus, the frequency 
phase, and the error impulse response obtained with the apparatus of the invention 

5 compared with conventional apparatus; 

- Figure 13 shows the amplitude of the transfer response of a filter 
together with a few points interpolated with apparatus of the invention; 

- Figure 14 shows the impulse response of the Figure 13 filter without 
interpolation, and extended by zeros; 

10 - Figure 15 shows the impulse response of the Figure 13 filter with 

interpolation; 

- Figure 16 shows the error in impulse response between the Figure 14 
filter extended by zeros in the time domain and the interpolated filter of Figure 13; 

- Figures 17 to 21 show five variant adaptive filter apparatuses of the 

15 invention; 

- Figure 22 is a diagram of a conventional type of echo canceller; 

- Figure 23 shows a known echo canceller in functional detail; 

- Figure 24 shows an echo canceller of the invention in functional detail; 

- Figure 25 shows apparatus for cancelling echo and noise; and 

20 - Figure 26 shows apparatus that performs the same function as that of 

Figure 25, and implemented in accordance with the invention. 

First sound filter apparatus in accordance with the invention is described 
below with reference to Figure 17. 

This apparatus receives a discrete time domain signal at its input that is 

25 constituted by a plurality of blocks each consisting of 1024 samples in the non- 
limiting example described herein. This time domain signal is a sound or acoustic 
signal, for example representative of the speech of a user speaking into a microphone. 

In Figure 20, one of the time domain blocks is referenced S1(0,...,N-1), 
where N is equal to 1024. 

30 This signal SI is received by a first module Ml which performs a fast 

Fourier transform of order N on said signal , written FFT N , so as to provide a 
frequency domain signal having N samples X(0,...,N-1). This frequency domain 
signal is thus likewise a signal representative of a sound. Thus, in this case, this 
signal is an acoustic signal. 

35 Starting from this frequency domain vector X of size N, an adaptive filter 

H calculates a vector H(0,...,N-1), in which the N coefficients depend on the vector 
X. Each component of the vector H is calculated by an algorithm that uses 
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components of the vector X. This dependence is shown in Figure 17 by a double- 
shafted arrow. 

In conventional manner, such an adaptive filter H is for applying to the 
signal X from which it adapts itself, e.g. so as to cancel an echo detected in the signal 
5 X. 

Nevertheless, the N-coefficient filter H cannot be applied directly to X as 
obtained at the output from H. As explained above, the vector H must be processed so 
that its impulse response presents some non-zero number of coefficients that is less 
than a value N r that is less than N. In other words, the vector H must satisfy a linear 

1 0 convolution constraint before being convoluted with the vector X. 

To obtain a vector H f from the vector H and satisfying such a constraint, it 
is known to place a set of three modules at the output from the adaptive filter H: one 
module that performs an inverse transform of H into the time domain; a second 
module that multiplies the impulse response of the filter H by a rectangular window 

15 that keeps a portion of the impulse response unchanged and that replaces the tail 
portion of said response impulse with zeros; and a third module that performs a 
forward transform so as to obtain the frequency response of the filter H 1 corresponding 
to the truncated impulse response. 

Between the output from the adaptive filter H and a module for 

20 convolution with the signal X, the apparatus of Figure 17 presents a module M3 that 
performs processing in the frequency domain on the frequency domain vector 
H(0,...,N-1) without passing via the time domain, for the purpose of providing a 
frequency domain vector H' having N coefficients with an impulse response having 
non-zero values for its N' first coefficients only, said N' first coefficients being the 

25 same as the N' first coefficients of the impulse response of H. 

To perform such processing, the modulo M3 performs convolution of 
H(0,. . -,N-1) with a function U(k) that is given by: 



tm\ 1 • ( Lu ' 1 k 
U(k) = — sine - 



2 { 4 



kaiser(k,/?).e 



4 2 



where k lies in the range 0 to Lu-1, and U(k) is zero for values of k lying outside the 

30 range 0 to Lu-1 . The sine function in the above formula is given by: 

. , _ sin(^r.x) 
smc(x) = 



7T.X 



The sine function takes the value 1 when x=0. 

In the particular example described herein Lu is set to 7, such that Lu-1 is 
even, and such that (Lu-l)/4 is a multiple of 1/2. 
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The function U(k) can also be written: 



U(k) = — .sine 



1 . (k-K\ -M^\ 



v 0 



.e ^ 2 } Kaiser *(£, fJ) . 



\ ^ ) 

Such a function U(k) has a substantially rectangular window for its time 

domain transform, having a value of about 1 while k lies in the range 0 to 512, and 0 

for k lying in the range 512 to 1024. 

The inventors have come to a function having this form by observing that 



the function sine 



has, as its inverse discrete transform in the time domain, a 



function whose value is substantially constant and close to 2 for k lying in the range 0 
to N/4 and also for k lying in the range 3N/4 to N, while it takes values that are close 
10 to zero for k lying in the range N/4 to 3N/4. 

To obtain a frequency function U(k) corresponding to a time window that 
takes substantially the value 1 for k=0,...,N/2 and the value 0 for k=N/2,...,N-l, the 
inventors have used the property whereby multiplication in the frequency domain by a 

complex exponential e N , is equivalent to shifting the corresponding time domain 
1 5 function as obtained by the inverse Fourier transform through n 0 . 

In the present case, the inventors have used the value rto/N =1/4, 
producing a circular shift of one-fourth of the window of the inverse discrete 



(k\ 

transform of the function sine — 



thus making it possible to obtain the desired 



window. This window thus corresponds to a second half of the time domain signal 
20 being set to zero, and to the first half of the time domain signal being kept unchanged. 
More generally, it is possible to use a shift other than that proposed herein that applies 
to one-fourth of the window. In which case, use is made of the following function: 

U{k) = sinc\~^ye 1 2 } \ Kaiser (k,j3) 

where a is a constant selected to obtain the desired offset. Thus, a having a value 
25 equal to 2 corresponds to a time domain window which is zero over the first- and 
fourth-fourths of the time domain medium, and equal to 1 over a central portion of the 
medium, having a length equal to half that of the medium. The invention is therefore 
not limited to a having a value equal to 1 as described in the present particular 



embodiments. Another preferred embodiment of the invention has a = -1, which 
corresponds to zero in the first portion of the window. The person skilled in the art 
will adjust the value of a depending on which portion is to be set to zero, given the 
offset which is performed in circular manner. 
5 In this formula, the function U is multiplied by a conventional weighting 

window, in this case the kaiser window with p = 1.5. 

The conventional function of the weighting window is to reduce an error 
amplitude peak in the transform window of a truncated signal, in this case the 
following signal: 

(k-k\ A^) 

10 U{k) = smc[^j.e V 2 J 



truncated over the range 0<k<(Lu-l). 

Preferably, the weighting window is a window that is symmetrical about a 
value ko for k in which the function: 
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„ m . r*-M A^) 



presents its maximum for its modulus (in absolute value). In this way, the coefficients 
of the product of: 



U(k) = sinc|-^-|.e 



multiplied by said weighting window has the same properties as the coefficients of: 

20 y(t) , sinc i^. e H-^-J 



as described below, thereby providing significant advantages in terms of the amount 
of computation and memory size. 

The person skilled in the art can thus replace the kaiser window as 
proposed herein by any other known weighting window, for example a Harming 
25 window. 

In the present embodiment, where Lu=7, the following values of U are 
obtained for different values of k: 



k 0 1 2 3 4 5 6 

30 U(k) 0.0644j 0 0.3027j .5 -0.3027j 0 -0.0644j 



10 



2 

71 



It can be seen that the filter presents hermitian symmetry about the value 
k 0 of k for which: 

Lu-l ; k 0 _ Q 
4 2 

5 Because of this hermitian symmetry itself, only half of the coefficients of 

the filter U need to be calculated. In addition, because of this hermitian symmetry, 
convolution with U can be performed with the amount of computation required being 
reduced to close to 50%, as demonstrated below. 

It can also be observed that the coefficients of the filter alternate between 
10 being pure reals and pure imaginaries. This property comes from the fact that the 
argument of the factor: 

e 

is a linear function varying stepwise at a pitch of -j — and when k=0 has a value 

which is a multiple of j - 

15 This property comes from the fact that the filter is a half-band filter. 

Nevertheless, hermitian symmetry can also be obtained with a filter that is other than 
half-band, for example a filter corresponding to a window in which one-fourth of the 
time domain signal is set to zero. 

It can also be seen that every other coefficient of the filter U is zero, apart 
20 from the coefficient where k-3. The function sinc(x) is zero for all integer x other 
than zero. This property also stems from the fact that U is a half-band filter. Thus, 
for the coefficients given above, one coefficient in seven is zero. 

These three properties thus make it possible to achieve a major reduction 
in the amount of computation required. 
25 When U(k) is convoluted with H(k) by the module M3, a vector IT is 

provided that is expressed in the following form: 
H'(k+3) = H(k).U(6)+ H(k+l).U(5) + H(k+2).U(4) + H(k+3).U(3) + 
H(k+4).U(2) + H(k+5).U(1)+H(k+6).U(0) 
A coefficient of index k ? is thus calculated for H ? by convoluting U and H 
30 in such a manner that the coefficient of H having the same index k f is multiplied by 
the value of U having the maximum modulus. The other multiplications of this 
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convolution are performed by increasing the index of U when the index of H 
decreases, as with all convolutions. 

In other words, the function H' is equal to the convolution of H with a 

function of the form: 



U(k) = ~- s i nc 



{ 2 



where k 0 is zero. 

More generally, it is possible to use a function U having the form: 



U(k) = sine 



V 



2 2 



+ 2 + 2 



where the constant B is an integer selected in arbitrary manner and where P is a 
1 0 weighting window. 

The constant B offsets the function U(k) and that is easily taken into 
account by the person skilled in the art when computing the convolution, given the 
fact that to obtain the coefficient of given index k' of H', the convolution must be such 
that the coefficient of H having the same index k 1 must be multiplied by the maximum 
1 5 modulus coefficient of U. 

The fact that a function F2 is equal to the convolution of Fl and U 0 means 

that: 

F2(k) = Fl(k).U 0 (0) + Fl<k-l).U 0 (l) +Fl(k+l).U 0 (-l) + Fl(k-2).U 0 (2) + 

Fl(k+2).U 0 (-2)+... 
20 When U(k) = U 0 (k+B), the following can be written: 

F2(k)= Fl(k).U(-B) + Fl(k-l).U(-B+l) +Fl(k+l).U(-B-l) + . . . 
And thus: 

F2(k+B)=Fl(k+B).U(-B) + Fl(k+B-l).U(-B+l) +Fl(k+B+l).U(-B-l) + ... 

Providing the signal obtained by convolution is itself offset in suitable 
25 manner, the result of a convolution is unaffected by one of the functions involved in 
the convolution being itself offset by an integer number of samples. 

The module M3 can thus comprise a first unit performing the required 
multiplications and additions, and a second unit performing the offset. 

In the present case, and in accordance with the invention, convolution is 
30 performed between the input frequency domain signal H and the function U in such a 
manner, that in the convolution computation giving H' to the index k, H(k) is 
multiplied by the value reached by U when sinc(U) has a maximum, i.e. H(k) is 
multiplied by U(k+A) where A is such that the argument of the cardinal sine function 
(sine) is zero. 
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In this convolution, H(k+1) is thus multiplied by U(k+A-1), H(k-1) is 
multiplied by U(k+A+1), H(k+2) is multiplied by U(k+A-2), H(k-2) is multiplied by 
U(k+A+2), and more generally H(k+p) is multiplied by U(k+A-p). 

The inventors have found that by performing such a convolution with such 
5 a function U, a zero constraint is applied to half of the time domain signal 
coiresponding to H, with very satisfactory accuracy, and this is done while 
implementing a very small amount of computation, without any need to perform an 
inverse transform in the time domain. 

In the embodiment shown in Figure 17, for the filter U as described above, 
1 0 the following applies: 

U(1)=U(5)=0, U(0) =-U(6), U(l) =-U(5), and U(2) =-U(4). 

Thus: 

H'(k+3)-U(0).(H(k+6)~H(k))+U(2)(H(k+4)-H(k+2))+U(3)(H(k+3)) 7 

i.e.: 

1 5 H , (k+3)-U(0).A(k)+U(2)B(k)+U(3)(H(k+3)) 
with 

A(k)=H(k+6)-H(k) and B(k)=H(k+4)-H(k+2). 

Thus, instead of seven complex multiplications and six complex additions, 
i.e. 28 real multiplications and 26 real additions, convolution can be performed with 
20 six real multiplications and eight real additions. 

With apparatus different from that shown in Figure 17 but having a 
similar module M3, if the signal H is obtained by transforming a real time domain 
signal, then H presents hermitian symmetry of which advantage can be taken in like 
manner, thereby enabling the amount of computation required to be divided by two. 
25 The values of H(k) for k<0 and k>N-l can be obtained by using modulo N 

addressing (-1 corresponding to N-l, -2 to N-2, etc. . . .). 

Figures 1 and 2 show the signal H(k) in amplitude and in phase over the 
set of its 1024 points, while Figure 3 shows the impulse response h(i) over 1024 
points, corresponding to H(k). 
30 Figures 7 and 8 show the frequency domain signal FT obtained after 

convolution of H and U, respectively in amplitude and in phase. Figure 9 shows the 
impulse response h' corresponding to said signal. 

It can be seen that the impulse response h' is zero for the last 512 points 
while it remains unchanged over its first 512 points. 
35 The results obtained with the apparatus of the invention are compared 

below with the results obtained with conventional apparatus implementing an inverse 
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Fourier transform, setting the second portion of the impulse response to zero, and 
applying a Fourier transform to said truncated time domain signal. 

Thus, Figures 4 and 5 show the frequency domain signal obtained after the 
above three conventional processing steps, said signal being shown respectively in 
5 amplitude and in phase. Figure 6 shows the impulse response of the signal. 

Figures 10 and 11 show amplitude and phase error respectively between 
the frequency domain signals obtained using the conventional apparatus and the 
frequency domain signals obtained using the apparatus of the invention. 
Figure 12 shows the error in the impulse response. 
10 The person skilled in the art will observe that the resulting error is very 

small, and compatible with the required level of performance, particularly in speech- 
processing applications such as acoustic echo cancellation. 

A second apparatus of the invention is described below with reference to 
Figure 18. This apparatus receives at its input a time domain signal SI comprising 2N 
1 5 samples, where 2N is equal to 1024. A first module Ml implements a discrete Fourier 
transform on the 2N points of SI to supply a frequency domain vector X having 2N 
points, with indices lying in the range 0 to 2N-1 . 

A module M5 placed at the output of Ml decimates X(0,...,2N-1), so that 
every other coefficient in X is retained, thereby establishing a frequency domain 

20 vector X f (0,...,N-l). 

An adaptive filter that depends on X is provided at the output of M5 and 
delivers an N-coefficient vector H(0,..,N-1). Since the vector H has only N 
coefficients, it cannot be convoluted with X(0,. ..,2N-1). It is therefore necessary to 
construct a vector H ! (0,...,2N-1) having 2N coefficients that is based on H and that 
25 has an inverse transform whose first N samples are identical to those of the impulse 
response of H, and whose last N samples are zero. 

For this purpose, a module M3 is placed between the filter H and a 
convolution module operating with the function X(0,. . .,2N-1). 

At its input, the module M3 receives the frequency domain signal H with 
3 0 N=5 1 2 points, corresponding to 5 1 2 point impulse response. 

Starting from these N=512 frequency points, it is desired to obtain a 
function H r having 2N points. 

The module M3 comprises two modules M 3 ' and M 3 ". The first module 
M 3 ' inserts a zero after each of the N points of the signal H so as to obtain the signal 
35 H 0 (0,...,2N-1) having 2N=1024 points, where every other coefficient is zero, and 
more precisely where all of the coefficients of odd index are zero. 
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The frequency domain vector H 0 obtained in this way corresponds to an 
impulse response having 2N-1024 points in which the first N points are the same as 
those of the impulse response of H, to within a factor of X A. 

The impulse response of H thus remains unchanged by inserting zeros 

5 between the initial samples, provided the initial samples are in a signal that has been 
handed out on every other sample starting from the first index of the completed signal, 
i.e. starting from index 0 of the completed signal has indices starting from index 0. 
The samples of H are thus located at the even indices of H\ This insertion does not 
alter the first portion having 512 points of the impulse response. 

10 A second module M 3 " then performs completed frequency domain vector 

processing H 0 , which is similar to the processing described above with reference to 
Figure 17 and which has the effect of putting the last N points of the 2N point impulse 
response of H 0 to zero without altering the first N points, and doing so in the 
transform domain without returning to the time domain. 

15 In this case, a filter of length 15 is used whose coefficients are computed 

in a manner that is analogous to that used in the first embodiment. 

In the present case, every other value of the frequency domain signal H 0 
for convolution is zero. Thus, only one coefficient in two of the filter needs to be 
multiplied with a non-zero value of H 0 (k). 

20 Furthermore, by setting the second portion of the impulse response to zero 

and retaining its first half unchanged, there is no modification to the initial 512 
coefficients of the frequency function between which a zero has been inserted on each 
occasion as described above. 

Thus, the convolution of H 0 with a function U such as that suggested 

25 above, corresponding to a half-band time window, does not alter the 512 non-zero 
values of H 0? i.e. the values of H 0 (k) for which the even values of k lie in the range 0 
to 1022. 

As a result, only the zero values of H 0 (k) need to be recomputed by 
convolution. 

30 There is therefore no need to compute every other coefficient of the filter 

U. With a filter U of length 15 and achieving its maximum modulus, i.e. its hermitian 
symmetry point, for ko=7, i.e. with: 

U{k) = sincf -— — - + — kaiser (k,fi) 
V 4 2) 

and 

- ( Lu ~ l * 

35 U(k) = U (k)e 4 +2 
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and for Lu = 15, the following coefficients are obtained: 

k 0 2 4 6 7 8 10 12 14 

U(k) 0.0552j O.lOOlj 0.1952J 0.6308j 1 -0.6308J -0.1952J -O.lOOlj -0.0552J 

Lu is preferably selected to be odd so as to obtain equal numbers of 
5 coefficients on either side the point of symmetry of IL 

Since every other coefficient is not useful, the coefficients for 
computation are all purely imaginary and do indeed present hermitian symmetry about 
ko=7. 

As in the preceding case, computation is advantageously performed as 

10 follows: 

Writing A(k) = Z(k+14)-Z(k) 

B(k) = Z(k+12)-Z(k+2) 
C(k) = Z(k+10)-Z(k+4) 
D(k) = Z(k+8)-Z(k+6) 

1 5 and with k n = Lu ~ l = 7 , the following interpolated result is obtained: 

2 

f H(£) if k is even 

H ' W = [U(0)A(k - 7) + U(2)B(k - 7) + U(4)C(k - 7) + U(6)D(k - 7) if k is odd 

Computation thus amounts to eight real multiplications and 14 real 
additions for each of the calculated points. 

Naturally, in apparatus that differs from that shown in Figure 18, but that 
20 has a similar module M3, the vector H for interpolation can be the transform of the 
time domain signal and this time domain signal can be real. In which case, the 
complexity of the computation is further reduced by a factor of 2 by hermitian 
symmetry of h; 

Results corresponding to this example are described below. 
25 The accompanying figures show: 

- in Figure 13, the modulus of the transform function of the filter H for 
various points, together with various interpolated points for forming the vector IT; 

- in Figure 14, the impulse response of a filter H M obtained from that of H 
by the conventional method consisting in two fast Fourier transforms between which 

30 the impulse response of H is extended by 5 1 2 zeros; 

- in Figure 15, the impulse response of the filter IT obtained at the output 
from the module M3 of the apparatus shown in Figure 18; and 

- in Figure 16, the error between the impulse response of the filter H" and 
the impulse response of the filter H\ 
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The person skilled in the art will observe that the resulting error is here 
again compatible with the required performance, particularly in applications 
associated with transmitting speech, such as removing noise by means of optimum 
filtering. 

5 In the apparatus of the invention, suitable filtering is used to replace the 

following complex sequence of operations: inverse transform, windowing or 
extension by means of zeros; and then forward transform. This low complexity 
filtering is applicable directly to the data coming from the transform, which transform 
is frequently the Fourier transform. 

10 In a first variant, the apparatus makes it possible to approximate, with 

accuracy appropriate to the application, to time domain windowing in which M 
consecutive samples of a block of T samples (M<T) are set to zero. The filtering 
applied to the data in the transform domain can be considered as equivalent to lowpass 
filtering, i.e. to smoothing. 

15 In a second variant, the apparatus makes it possible, to within a degree of 

accuracy that is appropriate to the application, to approximate extending a block of N 
samples with M zeros. The filtering applied to the data in the transform domain can 
then be considered as interpolation suitable for constructing the M missing points so 
as to extend the frequency data to N+M points. 

20 Figures 19, 20, and 21 show other examples of apparatus in accordance 

with the invention. 

Each apparatus shown in Figures 19, 20, and 21 has a variable coefficient 
adaptive filter H with N or 2N coefficients. Each apparatus has a module Ml whose 
input receives a time domain signal SI and which performs a Fourier transform on 
25 said signal. 

The input of the first module Ml of the apparatus shown in Figure 19 
receives a time domain block SI having N samples. This module Ml applies an N- 
point discrete Fourier transform to said signal SI and thus delivers the Fourier 
transform X of said block of N data samples. 
30 In Figure 20, the module Ml pads out the signal SI with zeros so as to 

obtain a signal having 2N coefficients, after which it performs a 2N-coefficient 
discrete Fourier transform on said padded-out signal. 

In both of the above apparatuses, the transfer function H of the filter is 
computed using the Fourier transform X output by the module Ml and is adapted as a 
35 function of said Fourier transform X. This dependency is represented by the vertical 
double-shafted arrow. 
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In Figure 19, at the output from the module Ml, the apparatus has a 
module M2 which performs the two above-described operations of adding a zero 
between each pair of values in the N-coefficient signal X, so as to obtain a signal 
X'(0,..,,2N-1), and then implements convolution between the signal X f and a filter U 
5 of the kind described above. 

Thus, the module M2 performs interpolation so as to extend the size of the 
Fourier transform directly to 2N frequency points starting from the signal X that has 
only N points, where X' has an impulse response equivalent to the impulse response of 
X extended by zeros. 

10 The apparatus of Figure 19 also has a module M3 performing the same 

interpolation operation on the transfer function H of the N-point filter, i.e. it inserts a 
zero between each pair of values in H, and then performs convolution with a function 
U of the kind described above, corresponding to zeroing a second portion of the 
impulse response of the 2N-point filter that is obtained, by inserting zeros. 

15 Thus, in Figure 19, a frequency domain signal is obtained at the output 

from the module M2 that is representative of a time domain signal having 2N points 
of which the first N points belong to the input signal SI. A frequency domain signal 
S3 having 2N points is obtained at the output from the module M3, and its impulse 
response has 2N points presenting for the first N points the same values as the impulse 

20 response of the filter H, and for the last N points, values of zero. 

These two frequency domain signals S2 and S3 each having 2N points are 
subsequently multiplied in a multiplier module M4 which can equally well be a 
module that implements correlation or convolution between S2 and S3. 

The apparatus of Figure 20 is similar in structure to that of Figure 1 8, 

25 except that the adaptive filter H has 2N coefficients, and the module M3 sets the last 
N coefficients of the impulse response of the filter to zero from the frequency domain. 
Smoothing thus makes it possible to achieve the equivalent of the linear convolution 
constraint and to limit the length of the impulse response of the filter to N points. 

The frequency response H' obtained in this way is multiplied by the vector 

30 X in an output multiplier module M4. 

Figure 21 shows apparatus having the same structure as that described 
with reference to Figure 18, except that the module Ml supplies an N-sample 
frequency transform and the decimator applies decimation to the N-sample Fourier 
transform X of the N data item block while retaining only one point in every D points 

35 (where D is an integer greater than or equal to 2). 

This provides a vector X' having N/D points, from which it is possible to 
adapt the transfer function of the filter H, said transfer function H having L=N/D 
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points. As for the apparatus of Figure 18, a transfer function H 1 having N points is 
reconstituted by interpolation in a module M3 of the same kind as described in detail 
above, serving to perform linear convolution between H' and X in a multiplier module 
M5. 

5 Within M3, a first module M 3 ! introduces some number D of zeros after 

each sample of H. The frequency domain signal H 0 obtained in this way corresponds 
to an impulse response having D.L points in which the first L points are the same as 
those of the impulse response of H. The impulse response of H remains unchanged by 
introducing zeros between the initial samples. 

10 A second submodule M 3 " then processes the resulting D.L point frequency 

domain signal H 0 so as to set the (D-l).L last points of the D.L point impulse response 
of H 0 to zero without altering the L first points of said impulse response. This 
provides the desired frequency domain vector FT having N=D.L points. 

Such decimation has the advantage of significantly reducing the amount of 

15 computation required for adapting the filter H; it is applicable when the transfer 
function of the filter is fairly regular so that it can be decimated without critical loss of 
information. 

By means of the invention, it will be observed that it is possible to use filters 
having a very small number of coefficients. 
20 There follows a description of apparatus for cancelling acoustic echo, and 

apparatus for reducing some disturbance (noise or echo) by implementing apparatus of 
the invention. 

As is well known in certain applications for transmitting speech, such as 
hands-free telephony or remote conferencing, appropriate apparatus needs to be used 
25 to counter acoustic echo which would otherwise constitute a significant source of 
difficultly in conversation. 

In the state of the art, such apparatus, as shown in Figure 22, implements an 
adaptive filter AF whose function is to identify and model the impulse response of the 
acoustic coupling path between a loudspeaker LS and a microphone MIC of the 
30 hands-free telephone terminal or the remote conferencing system. 

This portion of the apparatus is shown in Figure 22 and is referred to as an 
acoustic echo canceller. 

Practical embodiments of such apparatus can have a wide variety of 
implementations, for example those described in document [8]. 
35 The coefficients of the adaptive filter AF are adapted over time by some 

suitable algorithm making use of a received speech signal and an estimate of the error 
presented on the speech signal that is transmitted from the microphone MIC and after 
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application of the filter AF to said signal. A conventional algorithm for adapting the 
coefficients of the filter AF is known under the name stochastic gradient or LMS, 

In this case computation is performed in blocks, using the Fourier transform 
or the Hartley transform since this form requires a volume of computation that is 
5 much smaller than that required for the conventional time domain form. 

Figure 23 is a block diagram showing a typical implementation of an echo 
canceller. This apparatus has modules CI and C2 respectively for applying a 
correlation calculation constraint and a linear convolution constraint. It will be 
observed that these modules CI and C2 apply these constraints directly on a time 
10 domain signal and each of them is thus located between an inverse transform module 
and a forward transform module. 

Figure 24 is a block diagram of an echo canceller implemented in 
accordance with the invention. 

In this apparatus, the modules CI and C2 and the inverse and forward 
15 transform modules on either side of them has been replaced on each occasion by a 
smoothing module that does not involve computing a transform whether forward or 
reverse. 

The following table summarizes the volume of computation that needs to be 
performed to process a real sample block for a conventional constraint module having 
20 transforms of size T and for a frequency smoothing filter having seven coefficients 
and using the computation reductions proposed above: 





Conventional form 


Type of 
operation 


Form modified by the 
invention 


Cl 


2Tlog 2 T 


(x) 


3T 




2Tlog 2 T 


(+) 


4T 


C2 


4Tlog 2 T+T 


(x) 


3T 




4Tlog 2 T 


(+) 


4T 
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Thus, considering a transform of size T = 1024, this becomes: 





Conventional form 


Type of 
operation 


Form modified by the 
invention 


CI 


20 xl024 


(x) 


3 x 1024 




20 x 1024 


(+) 


4 x 1024 


C2 


41 x 1024 


(x) 


3 x 1024 




40 x 1024 


(+) 


4 x 1024 



Using apparatus of the invention thus provides a saving of 109,568 
5 arithmetical operations, all types of operation combined (the total number of 
operations being reduced to 14,336). 

It is also well known that in speech transmission applications, the 
background noise picked up by the microphone of the terminal can give rise to 
difficulty for remote users (noise level can be very high during a telephone 
10 conversation taking place from a hands-free radiotelephone terminal installed in a 
vehicle). 

Similarly, for a transmission system installed in a room, it is well known that 
in the absence of echo cancelling apparatus based on the principle of Figure 22, or 
even in the presence of echo cancelling apparatus but having an adaptive filter of 
15 length that is significantly shorter than the acoustic response of the room, the echo 
present on the transmitted speech channel can give rise to serious difficulties for such 
remote users. 

In the conventional state of the art, techniques based on using a variable 
attenuator ("variable gain" techniques) are employed to reduce the difficulty due to 
20 echo. In more advanced state of the art equipment, variable filters adapted on the 
basis of the characteristics of the various signals ("optimum" filters) are used for this 
purpose and provide better subjective quality. Such variable filters can be effective in 
reducing the noise present on the speech as transmitted. 

Figure 25 shows apparatus based both on using an echo canceller and on 
25 using an optimum filter to reduce disturbance made up of noise and/or echo. 

The echo canceller module of this apparatus of the invention comprises a 
loudspeaker 100, a microphone 200, a subtracter 300, and a filter unit 400. 

This filter unit 400 has a first input receiving a signal x(t) that also reaches 
the loudspeaker 100, the filter unit also has a second input that receives a signal which 
30 is obtained at the output from the subtracter module 300, by subtracting from a 
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microphone signal y(t) transformed into the frequency domain a signal that is obtained 
by applying the filter module to the loudspeaker signal x(t). 

The echo canceller module has two branches which meet at a multiplier 450. 
A first one of these branches has a module 410 for applying a forward Fourier 
5 transform to the loudspeaker signal x(t), and a module 420 for conjugating the 
transformed signaL The second branch has a constraint module CI applying a 
constraint on a signal Y' to calculate an error vector, and a multiplier module 440 at 
the output from the constraint module CI to be multiplied by a normalization matrix. 
The multiplier module 450 multiplies the loudspeaker vector as transformed and 

10 conjugated, by the error vector as multiplied by the normalization matrix. 

The multiplication module 450 delivers a frequency domain vector to a 
constraint module C2. At the output from the constraint module C2, there is placed a 
module 470 for updating the coefficients of an adaptive filter of the echo canceller. 
The filter updated in this way is applied to the transform of the loudspeaker signal x(t) 

15 in a multiplier module 480 located at the output from the update apparatus 470 and 
upstream from the subtracter 300. 

The apparatus of the invention presents a fundamental advantage over 
conventional apparatuses whereby the frequency domain signal to which the filter is 
applied in the module 480 is no longer transformed immediately into the time domain 

20 to be subtracted from the time domain signal y(t) as input by the microphone, but is 
kept in the frequency domain. Thus, in this apparatus, it is the microphone signal y(t) 
which is transformed into the frequency domain to enable the estimated echo signal as 
obtained from the output of the multiplier 480 and as retained in the frequency domain 
to be subtracted from this microphone signal as transformed into the frequency 

25 domain. This subtraction operation in the frequency domain takes place in the 
subtracter 300 which is disposed between the module 480 for applying the adaptive 
echo cancelling filter and a forward Fourier transform module 495 at the output from 
the microphone. 

Within this apparatus, it is not a time domain error signal corresponding to 
30 the microphone signal from which the estimated echo signal has been subtracted that 
is transmitted to the constraint module CI. The constraint module CI receives an 
frequency error vector without any return to the time domain between calculating this 
error vector and the constraint module CI. This frequency error vector is equal to the 
difference between the frequency transform of the loudspeaker signal to which the 
35 adaptive filter 470 is applied and the microphone signal as transformed into the 
frequency domain. Thus, the constraint module CI, unlike conventional apparatuses, 
does not present two submodules, but three submodules constituted successively by a 
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first submodule 432 performing the inverse Fourier transform into the time domain, a 
second submodule 435 for zeroing an initial portion of the time domain signal 
obtained at the output from the module 432, and a third submodule 438 receiving the 
truncated time domain signal and applying a forward Fourier transform into the 
5 frequency domain. 

Thus, the constraint module CI performs processing on the frequency error 
vector it receives that is equivalent to truncating the time domain transform of this 
frequency error signal. 

The frequency error signal Y' is thus used by the unit made up of the CI 
10 constraint module 430, the C2 constraint module 460, the multiplier module 450, and 
the conjugating module 420 to calculate a new set of coefficients for the adaptive 
filter with a new block of samples x((t+l)B), which new set of coefficients is applied 
to the new loudspeaker data block x((t+l)B) so as to deliver a new vector Y\ 

The signal Y' obtained at the output from the subtracter 300 is delivered not 
15 only to the constraint module CI, but also to the second portion of the apparatus that 
serves to reduce disturbances. 

This is itself conventional in structure. The signal Y f obtained at the output 
from the echo canceller is supplied to the input of a loop 500 passing successively 
through two modules 520 and 530. The module 520 calculates coefficients for the 
20 disturbance-reducing filter on the basis of the frequency domain signal Y\ The 
frequency domain vector output from this first module 520 is applied to a module 530 
which applies a constraint C3 on the frequency domain vector. The module 530 
comprises three submodules, a first submodule 532 performing an inverse Fourier 
transform on the frequency domain vector output by the module 520 so as to obtain 
25 the time domain signal that corresponds to said vector. This time domain signal is 
then subjected to a submodule 536 which zeros a portion of this vector, and more 
precisely zeros a final portion thereof, after which the truncated time domain vector is 
subjected to a forward Fourier transform in a third submodule 538. The loop 500 thus 
supplies a disturbance-reducing filter whose frequency coefficients are such that their 
30 inverse Fourier transform has a reduced number of non-zero coefficients. 

The frequency domain vector obtained at the output from the second module 
530 is applied to the frequency error signal Y ! in a multiplier module 600. This 
provides a frequency domain signal Z' corresponding to the Fourier transform of a 
time domain signal whose echo has been cancelled and whose disturbances, in this 
35 case noise, have been reduced. 

The resulting frequency domain vector Z ! is then transformed into the time 
domain by an output module 700 that applies an inverse Fourier transform to the 
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signal Z\ A block of time samples is then obtained from which the echo has been 

cancelled and in which disturbances have been reduced. 

It will also be observed that there is a module 800 disposed at the output 

from said apparatus so as to convert from a block rate to a sample rate. The resulting 
5 sound message is then transmitted to a remote party who therefore receives the sound 

signal present at the microphone 200 at a given instant from which the echo and noise 

have been eliminated. 

This apparatus thus makes it possible to eliminate a forward Fourier 

transform module that would conventionally be required between an error computing 
10 module and a module for reducing disturbances when two such modules are coupled 

together. The frequency domain signal Y' is thus delivered directly to the loop 500 

and in particular to the first module of said loop that performs disturbance-reducing 

filter computation. 

Thus, the output from the constraint module 530 provides a set of 
15 disturbance-reducing filter coefficients adapted as a function of the signal Y'. 

The apparatus described above has a noise reducer. Nevertheless, the noise 
reducer can be replaced by an echo reducing module, a reducer that diminishes a 
mixture of echo and noise, or more generally any disturbance reducer. 

It may be observed that three constraint modules Cl ? C2, and C3 are present, 
20 each of which is constituted by a module for zeroing a portion of a time domain signal 
lying between two transform modules, one inverse and the other forward. The 
constraint C3 can be thought of as a linear convolution constraint. In the invention, 
C3 can be considered as being means for smoothing the frequency response of the 
filter and for controlling the selectivity of the filter by limiting its time domain 
25 medium and thus zeroing as many samples as necessary for subsequently performing 
a transform of size T. 

In the invention, each of the three constraint modules CI, C2, and C3 is 
replaced by a frequency smoothing module. Depending on the desired objective, the 
constraint C3 can be replaced by a frequency smoothing module or by an interpolation 
30 module of the invention. The volume of computation performed in the apparatus of 
the invention is considerably smaller than that in the conventional apparatus. 

Thus, in Figure 25, making an echo canceller combined with optimized 
disturbance reduction by filtering requires nine transforms to be used. The apparatus 
of Figure 26 differs from that described above with reference to Figure 25 only in that 
35 the three constraint modules CI, C2, and C3 are replaced by smoothing modules 
implementing convolution with a function U of the kind described previously. 
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As shown in Figure 26, a corresponding system of the invention requires 
only three transforms and three smoothing modules, each of the three smoothing 
modules replacing a set of two transforms and one time domain constraint. 

The following table gives the volume of computation that needs to be 
performed to implement the constraints Cl, C2, and C2 for a transform of size T 
(Figure 25), and for a frequency smoothing filter having seven coefficients 
(Figure 26): 





Conventional form 


Type of 


Form modified by the invention 






operation 




Cl 


4Tlog 2 T + T 


(x) 


4T 




4Tlog 2 T 


(+) 


7T 


C2 


4Tlog 2 T + T 


(x) 


4T 




4Tlog 2 T 


(+) 


7T 


C3 


4Tlog 2 T + T 


(x) 


4T 




4Tlog 2 T 


(+) 


7T 


Thus, for a transform of size T = 1024, this amounts to: 




Conventional form 


Type of 


Form modified by the invention 






operation 




Cl 


41 x 1024 


(x) 


4x 1024 




40 x 1024 


(+) 


7x 1024 


C2 


41 x 1024 


(x) 


4 x 1024 




40 x 1024 


(+) 


7 x 1024 


C3 


41 x 1024 


(x) 


4 x 1024 




40 x 1024 


(+) 


7 x 1024 



Using apparatus of the invention thus provides a saving of 215,040 
arithmetical operations, all operations combined. (With the total number of 
operations being reduced to 33,792.) 

It makes it possible to act directly in the transform domain, i.e. in the 
frequency domain, the equivalent of zeroing a given number of time domain 
coefficients (smoothing) or the equivalent of adding a given number of zeros in the 
time domain (interpolation), which condition is necessary to avoid generating circular 
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convolution/correlation when filtering/correlation is performed in the transform 
domain, as is explained in detail in document [6]. 

Thus, apparatus as shown in Figure 25 is particularly well adapted to 
obtaining a significant reduction in computation by using a function U of the kind 
5 described above. Such apparatus provided with such smoothing modules makes it 
possible to implement echo cancellation and disturbance reduction completely in the 
frequency domain, without returning into the time domain which is expensive in 
computation. 

The various apparatuses described can be implemented using state of the art 
10 means, in particular real time digital signal processors (DSPs) typically using floating 
point arithmetic, e.g. those commonly used in audio and telecommunications 
applications (e.g. TMS320C3X or TMS320C4X from Texas Instruments); fixed point 
arithmetic processors can also be used providing the usual precautions are taken to 
frame the data appropriately during processing. It should be observed that the 
15 invention not only presents advantages in terms of complexity, but also makes 
implementation easier (there is no "scrambling" type permutation, there are fewer 
framing problems when performing fixed point computation, programming is simpler, 
addressing is simpler, ...). 

Apparatus of the invention is thus most advantageous whenever time 
20 variable filtering is performed and work is done in the transform domain. 

This covers not only the adaptive filtering used in echo cancelling, but also, 
more generally, any adaptive filtering in multiple uses: removing noise, separating 
signals, etc. 

A typical context for applying apparatus of the invention is described in [7], 
25 where conventional apparatus having two transforms on either side of a windowing 
module is used for giving selective characteristics to a filter by modifying the size of 
its impulse response. 

In certain embodiments described herein, U is convoluted with a function X 
which is the discrete Fourier transform of a discrete time domain signal. Naturally, a 
30 function U of the kind described above applies in the same manner to frequency 
domain signals corresponding to a discrete Fourier transform of a continuous time 
domain signal. 
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CLAIMS 

1/ Digital data processing apparatus comprising a module (M2, M3, M 3 ") 
implementing convolution with a function U on a frequency domain data vector Z(k) 
where k lies in the range 0 to N-l, which convolution corresponds to zeroing samples 
in the time domain of the inverse transform of Z(k), the apparatus being characterized 
in that the function U has the form: 



U(k) = sine 



V 2 



where k 0 is a constant integer and P(k) is a weighting window that is symmetrical 
about Icq. 

2/ Apparatus according to the preceding claim, characterized in that ko is equal to 
zero. 

3/ Apparatus according to either one of the preceding claims, characterized in that it 
comprises a module (M 3 r ) receiving a frequency domain vector (H), the module being 
suitable for inserting between two coefficients of the vector (H) on each occasion an 
additional coefficient so as to supply a frequency domain vector (IT) of increased 
length. 

4/ Apparatus according to the preceding claim, characterized in that the additional 
coefficients are zeros. 

5/ Apparatus according to claim 3 or 4, characterized in that for a frequency domain 
vector (H T ) of increased length having indices of 0 to 2N-1, the inserted coefficients 
are the coefficients having odd indices. 

6/ Apparatus according to any one of claims 3 to 5, characterized in that the module 
(M2, M3, M 3 ") performing convolution with U is placed downstream from the 
insertion module (M 3 r ), and in that Z is the frequency domain vector of increased 
length (H'). 

7/ Apparatus according to any preceding claim, characterized in that it includes a filter 
(H) upstream from the module (M2, M3, M 3 ") for performing convolution with U, 
and in that Z is the transfer function of this filter (H). 
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8/ Apparatus according to the preceding claim, characterized in that it includes means 
(H) for computing the coefficients of the filter (H) on the basis of a signal (X, SI) 
input to the apparatus. 

5 91 Apparatus according to any preceding claim, characterized in that it includes a 
module (Ml) suitable for implementing a transform into the frequency domain of an 
input time domain signal (SI), said module (Ml) being upstream from the module 
(M2, M3, M 3 ") for performing convolution with U, and in that Z is said frequency 
transform (X), possibly associated with an insertion module (M 3 ') in accordance with 

10 any one of claims 3 to 5. 

10/ Apparatus according to claims 6, 7, and 9 in combination, characterized in that it 
comprises a first module (M2) applying convolution with a first function having the 
form: 

(k-k ^ -4^^] 
15 U(k) = smc\^^\e 1 2 Kp(k) 

v 2 J 

on a frequency transform (X) of an input signal (SI) that is optionally augmented, and 
a second convolution module (M3) applying convolution with a second function 
having the form: 



(k-k\ -jJ4&&) 
C/(jfe) = sinc U 1 2 KP{k) 



v 



20 on the frequency response (H) of a filter (H) that is optionally augmented, the output 
vectors (X 1 , S3) from these two modules (M2, M3, M 3 ") having the same number of 
coefficients, and in that the apparatus has at its output a module (M4) suitable for 
multiplying together the coefficients of these two output vectors (X\ S3). 

25 11/ Apparatus according to any preceding claim in combination with any one of 
claims 3 to 5, characterized in that the module (M2, M3, M 3 M ) for performing 
convolution with U supplies an output vector (H', S3) having the same length as the 
augmented vector Z, by retaining in the output vector (H r , S3) those coefficients of the 
vector Z which were present prior to insertion, and the other coefficients of the output 

30 vector (H\ S3) being obtained by convolution of Z and U. 

12/ Apparatus according to any preceding claim, characterized in that the module 
(M2, M3, M 3 ") for performing convolution with U outputs a vector B(0,...,N-1) which 
is such that for all k, a coefficient in B of index k is equal to a product of convolution 



10 

W 15 

£ 20 

25 
30 



between Z and U which is such that the coefficient of index k in Z is multiplied in 
said convolution product with the coefficient of index Icq of U for which the sine 
function has an argument of 0. 

13/ Apparatus according to any preceding claim, characterized in that the filter U 
takes non-zero values over a range of values of k which is symmetrical about the 
value k 0 for which the modulus of U is at its maximum. 

14/ Apparatus according to any preceding claim, characterized in that the function U 
has an odd number of coefficients Lu, and in that U can be written: 



15/ Apparatus according to any preceding claim in combination with claim 9 or 10, 
characterized in that the transform is a discrete Fourier transform. 

16/ Apparatus according to any preceding claim, characterized in that the weighting 
window is a Kaiser window having a coefficient of 1.5. 

17/ Apparatus according to any preceding claim, characterized in that it constitutes an 
echo canceller. 

18/ Apparatus according to any preceding claim, characterized in that it constitutes a 
noise reducer. 

19/ Apparatus according to any preceding claim, characterized in that a = 1. 

20/ Apparatus according to any preceding claim, characterized in that a = -1. 

21/ Apparatus according to any preceding claim, characterized in that it comprises a 
loudspeaker (100), a microphone (200), an echo canceller (420, 430, 440, 450), and a 
disturbance reducer (500), the echo canceller including an adaptive filter (470) and a 
subtracter module (300) delivering the error (Y f ) between a signal coming from the 
microphone (200) and a signal obtained by applying the adaptive filter (460) to a 
loudspeaker signal (100), the adaptive filter (460) adapting its coefficients as a 
function of said error, and the apparatus including means (495) suitable for 
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transforming the signal from the microphone into the frequency domain upstream 
from the subtracter module (300) in such a manner that the subtraction is performed in 
the frequency domain. 

5 22/ Apparatus according to the preceding claim, characterized in that it has means 
(430, 440) for transmitting the result of said frequency domain subtraction to the 
adaptive filter (470) of the echo canceller. 

23/ Apparatus according to claim 21, characterized in that the disturbance reducer 
10 (500) is placed downstream from the subtracter module (300) and is applied in the 
frequency domain to the result of the subtraction. 

24/ Apparatus according to the preceding claim, characterized in that the disturbance 
reducer (500) includes an adaptive filter (520) suitable for recalculating its 
15 coefficients as a function of a frequency domain input signal (Y T ) from the disturbance 
reducer (500). 

25/ Apparatus according to the preceding claim, characterized in that the disturbance 
reducer (500) is placed to receive the frequency domain signal (Y T ) output from the 
20 subtracter module (300) as said frequency domain input signal of the disturbance 
reducer. 

26/ Apparatus according to claim 24 or 25, characterized in that the disturbance 
reducer (500) forms a loop receiving as input the frequency domain signal (Y r ) output 
25 from the subtracter (300), and applying at its output multiplication by the adapted 
coefficients of its adaptive filter on the frequency domain signal (Y) output by the 
subtracter (300). 

27/ Apparatus according to any one of claims 24 to 26, characterized in that the same 
30 frequency domain signal (Y ! ) is used as an error signal for adapting the adaptive filter 
(470) of the echo canceller and is multiplied by the coefficients of the adaptive filter 
(520) of the disturbance reducer (500). 

28/ Apparatus according to any one of claims 21 to 27, characterized in that no 
35 transform module is placed between the subtracter module (300) and the disturbance 
reducer (500). 
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